วิธีตั้งค่ากำหนดการ Stop EC2 Instance อัตโนมัติด้วย Amazon EventBridge

วิธีตั้งค่ากำหนดการ Stop EC2 Instance อัตโนมัติด้วย Amazon EventBridge

วิธีตั้งค่ากำหนดการ Stop Instance อัตโนมัติ เราจะทำการตั้งค่าใน Service ที่ชื่อว่า Amazon EventBridge โดยสาธิตการกำหนดเวลา Stop Instance รวมไปถึงการตรวจสอบประวัติการใช้งานใน CloudTrail และการลบ Feature ที่ได้สร้างและใช้งานไปใน Services ของ AWS
Clock Icon2022.02.07

この記事は公開されてから1年以上経過しています。情報が古い可能性がありますので、ご注意ください。

UI ของ Event Bridge เปลี่ยนไปมาก จึงทำการเขียนบทความใหม่ ดังนั้นโปรดดูที่บทความนี้

【Update】วิธีตั้งค่ากำหนดการ Stop EC2 Instance อัตโนมัติด้วย Amazon EventBridge

ครั้งนี้จะมาแนะนำวิธีตั้งค่ากำหนดการ Stop Instance อัตโนมัติด้วย Amazon EventBridge ต่อจากบทความ วิธีติดตั้ง Amazon Linux บน EC2 และเชื่อมต่อเซิร์ฟเวอร์ด้วยโปรแกรม PuTTy และ วิธีเชื่อมโยง Elastic IP (EIP) ไปยัง EC2 Instance

สิ่งที่ต้องมี

ก่อนอื่นต้องทำการติดตั้ง EC2 Instance สามารถดูวิธีการทำได้ที่คำอธิบายและลิงก์ด้านล่างนี้

※ชื่อ Key Pairs และ EC2 Instance ของบทความนี้คือtinnakorn-schedule-stop
※หัวข้อ ❌3. Connect to EC2 by PuTTY ไม่ต้องทำ
※Link : วิธีติดตั้ง Amazon Linux บน EC2 และเชื่อมต่อเซิร์ฟเวอร์ด้วยโปรแกรม PuTTy

เมื่อติดตั้ง EC2 Instance เสร็จเรียบร้อยแล้ว ให้ทำการเชื่อมโยง Elastic IP ไปยัง EC2 Instance เพื่อไม่ให้ IP Address เกิดการเปลี่ยนแปลง สามารถทำตามขั้นตอนที่ลิงก์ด้านล่างนี้ได้เลย

วิธีตั้งค่ากำหนดการ Stop EC2 Instance

เราจะสาธิตวิธีตั้งค่ากำหนดการ Stop EC2 Instance ใน Service Amazon EventBridge โดยจะใช้ชื่อว่าtinnakorn-schedule-stopซึ่งเป็นชื่อเดียวกับ Instance นั่นเอง

ค้นหา?︎ Amazon EventBridgeเลือกAmazon EventBridge
search_eventbridge

เมื่อเข้ามาที่ Amazon EventBridge แล้ว มาที่เมนูด้านซ้าย เลือกRules
menu_rules_eventbridge

มาที่หัวข้อ Rules คลิกCreate rule
cre_schedule_stop_ec2-1

เมื่อเข้ามาหน้า Create rule แล้ว สามารถดูการตั้งค่านี้เป็นแนวทางได้เลย
การตั้งค่าหัวข้อ Name and description นี้คือ:
» Name:tinnakorn-schedule-stop
» Description - optional:tinnakorn-schedule-stop
cre_schedule_stop_ec2-2

การตั้งค่าหัวข้อ Define pattern นี้คือ:
» Build or customize an Event Pattern or set a Schedule to invoke Targets.:⚫ Schedule
» เลือก⚫ Cron expression:ตามด้วยใส่วันที่และเวลาที่เราต้องการลบ:10 12 * * ? *10= นาที12= ชั่วโมง (UTC-7) => เวลาประเทศไทยคือ19:10นาที (+7)】
» เมื่อใส่วันที่และเวลาแล้ว จะมี Next 10 trigger date(s) ปรากฎขึ้นมา เลือก:Local time zone ▼
cre_schedule_stop_ec2-3

สามารถศึกษาเรื่อง Cron expression เพิ่มเติมได้ที่ : https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html


มาที่หน้า EC2 Instance ของเรา คลิกเพื่อ Copy Instance ID แล้วนำไปบันทึกไว้ที่ Notepad ก่อนก็ได้
cre_schedule_stop_ec2-4-fix

การตั้งค่าหัวข้อ Select targets นี้คือ:
Target
» เลือกEC2 StopInstances API call
» วาง Instance ID:i-*****************

⚫ Create a new role for this specific resource:tinnakorn-schedule-stop_Amazon_EventBridge_Invoke_Action
※ตัวอย่างการใส่ชื่อ role

# ชื่อ EC2 Instance ของเรา = "tinnakorn-schedule-stop_"

# ชื่อค่าเริ่มต้นของ Role = "Amazon_EventBridge_Invoke_Action_On_EC2_Instance_823471707"
# ให้ทำการลบตั้งแต่ "_On_EC2_Instance_823471707" ก็จะได้เป็น "Amazon_EventBridge_Invoke_Action"

# การรวมชื่อโดยการนำชื่อ EC2 Instance ของเรากับชื่อ role มารวมกันตามด้านล่างนี้
# "tinnakorn-schedule-stop_" + "Amazon_EventBridge_Invoke_Action" ก็จะได้เป็น "tinnakorn-schedule-stop_Amazon_EventBridge_Invoke_Action"

↓ ตัวอย่างนี้จะใส่ชื่อ role ตามด้านล่างนี้ แต่จริงๆ แล้วไม่ต้องทำแบบนี้ก็ได้ จะใส่ชื่ออะไรก็ได้ที่ทำให้เราจำง่ายที่สุด

tinnakorn-schedule-stop_Amazon_EventBridge_Invoke_Action

cre_schedule_stop_ec2-5

เลื่อนลงมาด้านล่างสุด คลิกCreate
cre_schedule_stop_ec2-6

เมื่อมาหน้านี้แล้ว ให้คลิกที่ชื่อ Rule ของเรา
cre_schedule_stop_ec2-7

จากนั้นตรวจสอบข้อมูลที่เราได้ตั้งค่าไว้ในหน้านี้
cre_schedule_stop_ec2-8-fix

กลับมาที่หน้า EC2 Instance ของเรา แล้วสังเกตการเปลี่ยนแปลงของ Instance ตามเวลาที่เราได้ระบุไว้
จะเห็นว่า Instance state เริ่ม Stopping
cre_schedule_stop_ec2-9-fix

เมื่อ Instance state เป็น Stopped การ Stop Instance ก็เสร็จสมบูรณ์
cre_schedule_stop_ec2-10-fix

ในกรณีที่เราต้องการใช้ Instance นี้อีกครั้ง ก็สามารถ Start Instance ด้วยตัวเองได้ปกติ
คลิกที่Instance state ▼เลือกStart instance
cre_schedule_stop_ec2-11-fix

เมื่อ Instance state เป็น Running ก็จะสามารถใช้งาน Instance ได้ตามปกติ
cre_schedule_stop_ec2-12-fix

การตรวจสอบข้อมูลการใช้งานย้อนหลังด้วย CloudTrail

เมื่อเราได้ดำเนินการสิ่งต่างๆ ใน AWS นี้ไปแล้ว เราสามารถเข้ามาตรวจสอบสิ่งที่ดำเนินการย้อนหลังได้ที่ CloudTrail

ค้นหา?︎ CloudTrail» เลือกCloudTrail
search_cloud_trail

เมื่อเข้ามาที่ CloudTrail แล้ว มาที่เมนูด้านซ้าย เลือกEvent history
menu_event_history_cloud_trail

มาที่ Event history ในส่วนนี้เราสามารถเลือกดูข้อมูลย้อนหลังที่ดำเนินการไปก่อนหน้านี้ได้
ตัวอย่างนี้จะเข้าไปดูที่StopInstances
cloud_trail-1

เมื่อเข้ามาหน้า StopInstance แล้ว สามารถตรวจสอบข้อมูลการ Stop Instance ได้ว่าเรียบร้อยดีหรือไม่
cloud_trail-2-fix

การลบ Features ที่สร้างใน Services ของ AWS

เมื่อเราสร้างและใช้งาน Features ต่างๆ ใน Services ของ AWS ไปแล้ว เราสามารถลบออกได้ด้วยตัวเองง่ายๆ สามารถทำตามขั้นตอนเหล่านี้ได้เลย

※สิ่งที่จะลบออกคือ:

  • Amazon EventBridge
  • IAM
    • Roles
    • Policies
  • Instance
    • Security Groups
    • Key Pairs

การลบ Rule ใน Amazon EventBridge

มาที่หน้า Amazon EventBridge
delete_event_bridge-1

คลิกที่คลิกDelete
delete_event_bridge-2

คลิกDelete
delete_event_bridge-3

การลบ Roles กับ Policies ใน IAM

※การลบ Roles ใน IAM

เข้ามาที่ Service IAM โดยค้นหา?︎ IAM» เลือกIAM
search_iam

จากนั้นเริ่มทำการลบ Features Roles กับ Policies ใน Service IAM ได้เลย

ทำการลบ Roles ตามนี้
มาที่เมนูด้านซ้าย เลือกRoles
ค้นหาโดยใส่ชื่อเดียวกับที่เราสร้าง role ไว้?︎ tinnakorn-schedule-stop+ Enter
Checkที่ชื่อของเรา
คลิกDelete
delete_iam-1

คัดลอกชื่อในช่องสีแดงมาวางในช่องด้านล่าง จากนั้นคลิกDelete
delete_iam-2

※การลบ Policies ใน IAM

ทำการลบ Policies ตามนี้
มาที่เมนูด้านซ้าย เลือกPolicies
ค้นหาโดยใส่ชื่อเดียวกับที่เราสร้าง role ไว้?︎ tinnakorn-schedule-stop+ Enter
Checkที่ชื่อของเรา
คลิกActions ▼
เลือกDelete
delete_iam-3

คัดลอกชื่อในช่องสีแดงมาวางในช่องด้านล่าง จากนั้นคลิกDelete
delete_iam-4

การลบ Instance, Security Groups, Key Pairs และ EIP ใน EC2

เข้ามาที่ Service EC2 โดยค้นหา?︎ EC2» เลือกEC2
Search-EC2

จากนั้นเริ่มทำการลบ Features Instance, Security Groups และ Key Pairs ใน Service EC2 ได้เลย

※การลบ Instance ใน EC2

มาที่เมนูด้านซ้ายตรงหัวข้อ ▼ Instance เลือกInstances
Instance-select

มาที่หน้า Instance ของเรา
d_instance-1-fix

คลิกInstance state ▼เลือกTerminate instance
d_instance-2-fix

คลิกTerminate
d_instance-3

เมื่อ Instance state เปลี่ยนเป็น ⊝Terminatedการ Terminated Instance ก็เสร็จสมบูรณ์
d_instance-4

※การลบ Security Groups ใน EC2
ก่อนที่เราจะทำการลบ Security Groups เราต้องทำการ Terminate Instance จนกว่า Instance State เปลี่ยนเป็น ⊝Terminatedจึงจะสามารถลบ Security Groups ได้ เพราะว่าถ้าการ Terminate ไม่เสร็จสมบูรณ์ ก็จะทำให้มีแจ้งเตือน Error และไม่สามารถลบได้นั่นเอง

มาที่เมนูด้านซ้ายตรงหัวข้อ ▼ Network & Security เลือกSecurity Groups
menu_security_groups

ค้นหาชื่อ Security Group ของเรา โดยใส่ชื่อเดียวกับ Instance ของเราลงไป
ตัวอย่างนี้คือ?︎ tinnakorn-schedule-stop+ Enter ตามด้วย Checkที่ชื่อของเรา
security_groups-1

คลิกActions ▼เลือกDelete security groups
security_groups-2

คลิกDelete
security_groups-3

※การลบ Key Pairs ใน EC2

มาที่เมนูด้านซ้ายตรงหัวข้อ ▼ Network & Security เลือกKey Pairs
menu_keypairs

ค้นหาชื่อ Key Pairs ของเรา โดยใส่ชื่อเดียวกับ Instance ของเราลงไป
ตัวอย่างนี้คือ?︎ tinnakorn-schedule-stop+ Enter ตามด้วย Checkที่ชื่อของเรา
d_keypairs-1

คลิกที่Actions ▼เลือกDelete
d_keypairs-2

พิมพ์คำว่าDeleteลงไป ตามด้วยคลิกDelete
d_keypairs-3

※การลบ Elastic IP (EIP) ใน EC2

มาที่เมนูด้านซ้ายตรงหัวข้อ ▼ Network & Security เลือกElastic IPs
menu_eip

การลบ EIP นี้คือ
» ค้นหาชื่อ Elastic IP addresses ของเรา ตัวอย่างนี้คือ?︎ tinnakorn-schedule-stop+ Enter
» Checkที่ชื่อของเรา (โดยปกติจะ Check ให้อยู่แล้ว)
» มาที่ด้านขวา คลิกActions ▼
» เลือกRelease Elastic IP addresses
delete_eip-1

คลิกRelease
delete_eip-2

สรุป

ในบทความนี้ก็ได้สาธิตวิธีตั้งค่ากำหนดการ Stop Instance อัตโนมัติด้วย Amazon EventBridge เรียบร้อยแล้ว ซึ่งการตั้งค่านี้ จะช่วยเพิ่มความสะดวกสบายในการทำงานให้กับเรามากยิ่งขึ้น เพราะเราสามารถกำหนดวัน เวลา ที่ต้องการ Stop Instance ได้โดยไม่ต้องรอจนกว่าจะถึงวันที่ต้องการ Stop Instance และไม่ต้องมาเสียเวลา Stop Instance ด้วยตัวเอง

ตัวอย่างเช่น ถ้าเราไม่ได้ใช้งานเซิร์ฟเวอร์ Instance ในตอนกลางคืน แต่บางครั้งอาจจะลืม Stop Instance ซึ่งเราสามารถ Stop Instance ด้วยการตั้งค่านี้ได้ตลอดเวลา นอกจากนี้ยังช่วยประหยัดค่าใช้จ่ายให้เรา และทำให้เราสามารถใช้งาน AWS ได้ในราคาที่ถูกลงอีกด้วย

ขอขอบคุณที่มา : EC2インスタンスのスケジュール起動がお手軽に実現できるようになっていた!

บทความที่เกี่ยวข้อง

Share this article

facebook logohatena logotwitter logo

© Classmethod, Inc. All rights reserved.